<template>
    <div class="container">
        <div class="left-side">
            <div class="panel">
                <Banner />
                <DataPanel />
                <ContentChart />
            </div>
            <a-row style="margin-top: 16px">
                <a-col :flex="1" class="panel" style="margin-right: 16px">
                    <PopularContent />
                </a-col>
                <a-col :flex="1" class="panel">
                    <CategoriesPercent />
                </a-col>
            </a-row>
        </div>
        <div class="right-side">
            <div class="panel module-wrap">
                <QuickOperation />
                <RecentlyVisited />
            </div>
            <div class="panel" style="margin-top: 16px">
                <Carousel />
            </div>
            <div class="panel" style="margin-top: 16px">
                <Announcement />
            </div>
            <div class="panel" style="margin-top: 16px">
                <Docs />
            </div>
        </div>
    </div>
</template>

<script>
import { defineComponent } from 'vue';
import Banner from './components/banner.vue';
import DataPanel from './components/data-panel.vue';
import ContentChart from './components/content-chart.vue';
import PopularContent from './components/popular-content.vue';
import CategoriesPercent from './components/categories-percent.vue';
import RecentlyVisited from './components/recently-visited.vue';
import QuickOperation from './components/quick-operation.vue';
import Announcement from './components/announcement.vue';
import Carousel from './components/carousel.vue';
import Docs from './components/docs.vue';

export default defineComponent({
    components: {
        Banner,
        DataPanel,
        ContentChart,
        PopularContent,
        CategoriesPercent,
        RecentlyVisited,
        QuickOperation,
        Announcement,
        Carousel,
        Docs,
    },
});
</script>

<style lang="less" scoped>
.container {
    display: flex;
    padding: 16px 20px 0;
    background-color: var(--color-fill-2);
}

.left-side {
    flex: 1;
    // overflow: auto;
}

.right-side {
    width: 280px;
    margin-left: 16px;
}

.panel {
    overflow: auto;
    background-color: var(--color-bg-2);
    border-radius: 4px;
}

:deep(.panel-border) {
    margin-bottom: 0;
    border-bottom: 1px solid rgb(var(--gray-2));
}

:deep(.icon) {
    display: inline-block;
    width: 32px;
    height: 32px;
    margin-bottom: 4px;
    color: rgb(var(--dark-gray-1));
    font-size: 16px;
    line-height: 32px;
    text-align: center;
    background-color: rgb(var(--gray-1));
    border-radius: 4px;
}

.module-wrap {
    background-color: var(--color-bg-2);
    border-radius: 4px;

    :deep(.text) {
        color: rgb(var(--gray-8));
        font-size: 12px;
        text-align: center;
    }

    :deep(.wrapper) {
        margin-bottom: 8px;
        text-align: center;
        cursor: pointer;

        &:last-child {
            .text {
                margin-bottom: 0;
            }
        }

        &:hover {
            .icon {
                color: rgb(var(--arcoblue-6));
                background-color: #e8f3ff;
            }

            .text {
                color: rgb(var(--arcoblue-6));
            }
        }
    }
}
</style>
